$(function () {
    // 1.1 获取裁剪区域的 DOM 元素
    var $image = $('#image')
    // 1.2 配置选项
    const options = {
        // 纵横比
        aspectRatio: 1,
        // 指定预览区域
        preview: '.img-preview'
    }

    // 1.3 创建裁剪区域
    $image.cropper(options)



    // 需求2,点击按钮选择图片
    $('#chooseImagebtn').on('click', function () {
        $('#chooseImagepng').click()
    })

    // 渲染图片
    $('#chooseImagepng').on('change', function () {
        //  获取文字对象
        let file = this.files[0]
        if (file === undefined) {
            return layui.layer.ms / g('墨迹什么玩意')
        }
        // 根据文件对象生成路径
        let url = URL.createObjectURL(file)

        $image.cropper('destroy')
            .attr('src', url)
            .cropper(options)
    })


    // 需求4 上传头像
    $('#uploadBtn').on('click', function () {
        let dataURL = $image
            .cropper('getCroppedCanvas', {
                width: 100,
                height: 100
            })
            .toDataURL('image/png')
        // console.log(dataURL);
        axios({
            method: 'POST',
            url: '/my/update/avatar',
            data: 'avatar=' + encodeURIComponent(dataURL)
        }).then(res => {
            if (res.data.status !== 0) {
                return layui.layer.msg(res.data.message)
            }
            layui.layer.msg('更换成功')
            window.parent.getUserInfo()
        })

    })
})

